



FIG. 1  
(PRIOR ART)



FIG. 2



FIG. 3



FIG. 4



FIG. 5



FIG. 6



FIG. 7



FIG. 8



FIG. 9

150<sup>2</sup>



P0x\_CTRL

| Name           | Extent | Access | Initial State | Firmware Init'd State | Description                                                                                                                                                                                                                                                                                                                         |
|----------------|--------|--------|---------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CACHE_LINE_LEN | 7:0    | RW     | 40            | Must Be 40            | Cache line size. Used by Megacell for PCI-2.2 Latency Timer expiration during MWI cycles.<br><code>csr2xcal_cacheline_size[7:0]</code>                                                                                                                                                                                              |
| DIS_64BIT_BUS  | 8      | RW     | 0             | 0                     | 0: Bus is 64 bits wide<br>1: Bus is 32 bits wide<br>This bit controls driving REQ64 at release of Reset. Megacell assumes this is the value of REQ64 latched on rising edge of pci_reset. Used to determine PCI(X) 64-bit bus capability. ( <code>csr2xcal_64bit_bus_en_n</code> )<br>This bit must be set (by firmware) on port 3. |
| DIS_ACK64      | 9      | RW     | 0             | 0                     | 0: Enable 64-bit Target capability on this port<br>1: Disable 64-bit Target capability<br>( <code>csr2xcal_64bit_tgt_en_n</code> )<br>This bit must be set (by firmware) on port 3.                                                                                                                                                 |
| DIS_REQ64      | 10     | RW     | 0             | 0                     | 0: Enable 64-bit Initiator capability<br>1: Disable 64-bit Initiator capability<br>( <code>csr2xcal_64bit_initr_en_n</code> )<br>This bit must be set (by firmware) on port 3.                                                                                                                                                      |
| DIS_BURST      | 11     | RW     | 0             | 0                     | 0: Enable PCI initiator burst capability.<br>1: Disable PCI initiator burst capability.<br>( <code>csr2xcal_initr_burst_en_n</code> )                                                                                                                                                                                               |
| Reserved       | 14:12  | RAZ    | 0             |                       |                                                                                                                                                                                                                                                                                                                                     |
| EN_IO7_PARK    | 15     | RW     | 0             | 0                     | 0: Park GNT on last master<br>1: Park GNT on IO7                                                                                                                                                                                                                                                                                    |
| Sp1_Cmp_MSG    | 19:16  | RW     | 0             |                       | Split Completion Message. This field is what IO7 will provide in the device specific field of a split completion message.                                                                                                                                                                                                           |
| EN_MSTR_LT     | 20     | RW     | 0             | 1                     | 0: follow the PCI spec for master latency (exception: disconnect at cache line boundaries)<br>1: ignore the master latency timer<br><code>csr2xcal_lattmr_disable</code>                                                                                                                                                            |
| EN_PCHK        | 21     | RW     | 0             | 1                     | Disables checking parity on AD[63::00] and C/BE[7::0]# during PCI address and data phases.<br><code>csr2xcal_par_en</code>                                                                                                                                                                                                          |
| Reserved       | 22     | RAZ    | 0             | 0                     |                                                                                                                                                                                                                                                                                                                                     |
| EN_TLB_CACHE   | 23     | RW     | 0             | 1                     | If set TLB entries will be cached coherently.<br>If clear TLB entries will be Fetched and translations discarded after first use. <code>csr2tlb_cache_ena</code>                                                                                                                                                                    |
| Reserved       | 25:24  | RAZ    | 0             |                       |                                                                                                                                                                                                                                                                                                                                     |

FIG. ~~10A~~  
10A

| Name             | Offset | Access | Initial State | Forward Limited State | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|--------|--------|---------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EN_ASSERT_SERR   | 26     | RW     | 0             | 0                     | Enable SERR assertion on PCI(X) bus. csr2p_serr_en<br>This bit has unexpected side effects in the x-caliber core. IO7 will correctly detect and log command/address/attribute parity errors with this bit clear and will target abort the effected transaction. Unwanted side effects of setting this bit include assertion of SERR# when the target of a PIO write asserts PERR#.                                                                                                                  |
| Reserved         | 27     | RAZ    | 0             |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RM_TYPE          | 29:28  | RW     | 01            | 01                    | Control the Prefetch algorithm used for PCI memory read multiple command.<br>00 = two DMA state machines (allows even distribution for a heavily populated bus)<br>01 = six DMA state machines (default)<br>10 = eight DMA state machines (for better single stream performance)<br>11 = eleven DMA state machines (never allow 12 on a read)                                                                                                                                                       |
| DIS_FUNC_ALIAS   | 30     | RW     | 0             | 0                     | 0: Allow IO7 to identify itself using multiple function numbers in PCI-X<br>1: IO7 uses only one function number                                                                                                                                                                                                                                                                                                                                                                                    |
| EN_AGP_RD_CACHE  | 31     | RW     | 0             | 0                     | This must always be set to 0 on Port 3<br>0: Disable prefetch data cache (only use Fetch commands) for PCI DMA read data<br>1: Enable prefetch data cache (use prefetch commands)                                                                                                                                                                                                                                                                                                                   |
| EN_PREFETCH      | 32     | RW     | 0             | 1                     | 0 = No prefetch; fetch minimum only<br>1 = Use Prefetch Prediction                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Reserved         | 33:32  | RAZ    | 0             | 0                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCI_ARB_MODE     | 36:35  | RW     | 0             | 0                     | 0: Round Robin<br>1: IO7 Priority Mode: IO7 is given the highest priority and is granted the bus whenever it is requested. When IO7 is not requesting the bus it is round robin.<br>2: Bus hog mode: device 0 ("slot 0") is given highest priority and is granted the bus whenever it is requested. Otherwise it is round robin.<br><br>Peer to peer is not supported to or from the "bus hog" device. UP_E_PCI_22_MODE must be 0 (strict round-robin) when running in Bus Hog mode.<br>3: reserved |
| EN_PCI_RD_CACHE  | 37     | RW     | 0             | 0                     | This should be set to 0 on PCI-X and to 1 or 0 on PCI buses. csr2upe_en_rd_cache<br>0: Disable prefetch data cache (only use Fetch commands) for PCI DMA read data<br>1: Enable prefetch data cache (use prefetch commands)                                                                                                                                                                                                                                                                         |
| UP_E_PCI_22_MODE | 38     | RW     | 0             | 0                     | PCI 2.2 read return (Down hose) ordering compliant mode: csr2upe_pci_22_mode<br>0 = Strict round-robin<br>(DMA/PPR fills MAY pass PIO/PPR Writes)                                                                                                                                                                                                                                                                                                                                                   |

FIG. 10B

| Name             | Extent | Access | Initial State | Comments<br>United States                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|--------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |        |        |               | 1 = IO7 Priority mode (2.2 compliant)<br>(DMA/PPR fills SHALL NOT pass PIO/PPR Writes)                                                                                                                                                                                                                                                                                                                                                                                                |
| UPE_ENG_EN<11:0> | 50:39  | RW     | 0             | FFF<br>Enable up state machine engines; one bit per engine.<br>Note: When there is peer-to-peer read traffic at least two engines must be enabled. This reservation is to avoid deadlock – writes always make progress.<br>Also note: Port 3 must have at least 4 engines enabled, UPE_ENG_EN<3:0> to support “AGP long reads” and to limit PCI to engines <11:4>.<br>Use this field to cause IO7 DMA to go quiescent in support of hot add or swap of a CPU.<br>csr2upe_eng_en[11:0] |
| ENA_AGP_ORDER    | 51     | RW     | 1             | 1<br><i>This bit effects Port 3 only</i><br>1: Use AGP ordering rules<br>(Up Host reads may bypass writes)<br>0: Use PCI ordering rules                                                                                                                                                                                                                                                                                                                                               |
| UPE_PPRWR_RX     | 52     | RW     | 0             | 0<br>Relax ordering for PPR Writes:<br>0 – Peer writes are not ordered with respect to other peer writes<br>1- Peer writes are ordered by limiting to one at a time.<br>csr2upe_pprwr_rx                                                                                                                                                                                                                                                                                              |
| HPCE_ENA         | 53     | RW     | 0             | Set to enable external hot plug logic.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Reserved         | 60:54  | RAZ    | 0             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AGP_MW           | 61     | RW     | 0             | 1<br>0: SBA48 is Logical “OR” of SBA address bits 47:32<br>(use Window 3 as 4G Scatter/Gather target)<br>1: SBA49 always set (AGP uses Monster Window only)<br>csr2agp_mw<br>Only meaningful on Port 3                                                                                                                                                                                                                                                                                |
| AGP_RD_CONCAT    | 62     | RW     | 0             | 1<br>Enable concatenation of reads from AGP<br>csr2agp_rd_concat<br>Only meaningful on Port 3                                                                                                                                                                                                                                                                                                                                                                                         |
| AGP_WR_CONCAT    | 63     | RW     | 0             | 1<br>Enable concatenation of writes from AGP<br>csr2agp_wr_concat<br>Only meaningful on Port 3                                                                                                                                                                                                                                                                                                                                                                                        |

FIG. ~~10c~~ 10c

1600

| Name         | Extent | Access | Initial State | EW | Unitred State | Description                                                                                                                                                                                                                   |
|--------------|--------|--------|---------------|----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UPH_PID      | 10:0   | RW     | x400          |    |               | PID<9:0> - PID of this device used in all request packets. Note that PID<9> is always set to 1 for IO7. <code>csr2uph_pid[10:0]</code>                                                                                        |
| UPH_CD_REQ   | 15:11  | RW     | 0             |    |               | Up Hose buffer credits:<br>Req <code>csr2mux_crdt_req[4:0]</code>                                                                                                                                                             |
| UPH_CD_RIO   | 20:16  | RW     | 0             |    |               | RdIO <code>csr2mux_crdt_rio[4:0]</code>                                                                                                                                                                                       |
| UPH_CD_WIO   | 25:21  | RW     | 0             |    |               | WrIO <code>csr2mux_crdt_wio[4:0]</code>                                                                                                                                                                                       |
| UPH_CD_BLK   | 30:26  | RW     | 1             |    |               | BlkResp <code>csr2mux_crdt_blk[4:0]</code>                                                                                                                                                                                    |
| UPH_CD_NBK   | 35:31  | RW     | 1             |    |               | NoBlk <code>csr2mux_crdt_nbk[4:0]</code>                                                                                                                                                                                      |
| UPH_FR_CNT   | 36     | RW     | 0             |    |               | <code>csr2uph_fr_cnt</code><br>0: Force errors as one-shot, single flit ASAP.<br>In this mode the UPH_FR_xxx bit is cleared by hardware after the error is posted.<br>1: Force errors once every $2^{20}$ forward clock ticks |
| UPH_FR_HDR   | 37     | RW     | 0             |    |               | <code>csr2uph_fr_hdr</code><br>0: Force errors on Data flit<br>1: Force errors on Header flit                                                                                                                                 |
| UPH_FR_SBE   | 38     | RW     | 0             |    |               | Force: Single Bit Error <code>csr2uph_fr_sbe</code>                                                                                                                                                                           |
| UPH_FR_DBE   | 39     | RW     | 0             |    |               | Double Bit Error <code>csr2uph_fr_dbe</code>                                                                                                                                                                                  |
| UPH_FR_GBG   | 40     | RW     | 0             |    |               | Garbage code <code>csr2uph_fr_gbg</code>                                                                                                                                                                                      |
| UPH_ARB_MODE | 42:41  | RW     | 0             |    |               | Controls priority of AGP relative to other ports. (Port 7 is first because all fwd-misses come through it).<br>0 – Port 7 first; round robin 0,1,2,3<br>1 – Port 7 first, Port 3 Second, round robin 0,1,2<br>2:3 - reserved  |
| Reserved     | 63:43  | RAZ    | 0             |    |               |                                                                                                                                                                                                                               |

FIG. ~~1600~~

11

1700



| Name            | Extent | Access | Initial State | Firmware Initialized State |                                                                                                                                                                                                                                   |
|-----------------|--------|--------|---------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UPE_FLUSH_CACHE | 0      | W/RAZ  | 0             | 0                          | Set to invalidate all (fetched) non-coherent blocks. VictimClean coherent blocks. Set by write or as a side effect of Fault Reset.<br>This appears the same as a forward hit on all cached data. <code>csr2upe_flush_cache</code> |
| UPE_CACHE_INV   | 1      | RO     | 0             |                            | Set when one or more blocks in TLB, read and write caches are valid (a pending request, victim or dirty data)<br>NOTE- this may never clear if there is an error. In error case just use PCI_RESET.                               |
| Reserved        | 2      | RAZ    | 0             |                            |                                                                                                                                                                                                                                   |
| PCI_RESET       | 3      | RW     | 0             | 1                          | 1: PCI reset not asserted<br>0: PCI Reset asserted.                                                                                                                                                                               |
| Reserved        | 63:4   | RAZ    | 0             |                            |                                                                                                                                                                                                                                   |

~1702

~1704

FIG. ~~TP~~ FB

12